{% extends 'layout/basic.html' %}
{% load static %}

{% block title %} 用户短信登录 {% endblock %}

{% block css %}
    <link rel="stylesheet" href="{% static 'css/account.css' %}">
    <style>
        .error-msg {
            color: red;
            position: absolute;
            font-size: 12px;
        }
    </style>
{% endblock %}

{% block content %}
    <div class="account">
        <div class="title">用户短信登录</div>
        <form id="smsForm" method="post" novalidate>
            {% csrf_token %}
            {% for item in form %}
                {% if item.name == 'code' %}
                    <div class="form-group">
                        <label for="{{ item.id_for_label }}">{{ item.label }}</label>
                        {#                        <div class="clearfix">#}
                        <div class="row">
                            <div class="col-xs-7">
                                {{ item }}
                                <span class="error-msg"></span>
                            </div>
                            <div class="col-xs-5">
                                <input id="btnSms" type="button" class="btn btn-success" value="点击获取验证码"/>
                            </div>
                        </div>
                    </div>
                {% else %}
                    <div class="form-group">
                        <label for="{{ item.id_for_label }}">{{ item.label }}</label>
                        {{ item }}
                        <span class="error-msg"></span>
                    </div>
                {% endif %}
            {% endfor %}

            <div>
                <div style="float: right">
                    <a href="/login/">手机号&邮箱登录</a>
                </div>
            </div>

            <div class="row">
                <div class="col-xs-3">
                    <input id="btnSubmit" type="button" class="btn btn-primary" value="登 录"/>
                </div>
            </div>
        </form>
    </div>
{% endblock %}

{% block js %}
    <script>
        $(function () {
            binkClickBtnSms();
            binkClickSubmit();
        });

        /*
            点击获取验证码的按钮事件
        */
        function binkClickBtnSms() {
            $('#btnSms').click(function () {
                // 验证错误每点击前都要清空
                $('.error-msg').empty()

                // 获取用户输入的手机号
                var mobilePhone = $('#id_mobile_phone').val();

                // 发送ajax请求 把获取的手机号发送到后台
                $.ajax({
                    {# 等价于 {% url "send_sms" %} #}
                    {#url: '{% url 'send_sms' %}',#}
                    url: '/send/sms/',
                    {#url: 'http://127.0.0.1:8000/web/send/sms/',#}
                    type: 'get',
                    data: {mobile_phone: mobilePhone, tpl: 'login'},    // 发送的数据
                    dataType: 'JSON', // 将服务端返回的数据反序列化成字典
                    success: function (res) {
                        // ajax请求发送成功之后 自动回调（执行）的函数
                        // res 是后端返回的值
                        if (res.status) {
                            console.log(res)
                            {#alert('发送成功 倒计时')#}
                            // var register = res.register
                            sendSmsRemind()
                        } else {
                            // 错误信息
                            console.log(res)    //{status: false, error: ['错误信息']}
                            $.each(res.error, function (key, value) {
                                $('#id_' + key).next().text(value[0])
                            })
                        }
                    }
                });
            });
        }

        /*
            倒计时
        */
        function sendSmsRemind() {
            var $smsBtn = $('#btnSms')

            $smsBtn.prop('disabled', true);  // 静用

            var time = 60;
            var remind = setInterval(function () {
                $smsBtn.val(time + '秒重新发送');
                time = time - 1;
                if (time < 1) {
                    clearInterval(remind);
                    $smsBtn.val('点击发送验证码').prop('disabled', false);
                }
            }, 1000)
        }


        /*
        点击登录
         */
        function binkClickSubmit() {
            $('#btnSubmit').click(function () {
                // 验证错误每点击前都要清空
                $('.error-msg').empty()

                // 1，收集表单中的数据(可以一个一个的找)
                // 可以用$('#regForm').serialize()

                //    $('#regForm').serialize()     // 包含表单中所有字段的数据 + csrf_token
                $.ajax({
                    url: "/login/sms_post/",
                    {#url: "http://127.0.0.1:8000/login/sms_post/",#}
                    type: "POST",
                    data: $('#smsForm').serialize(),
                    dataType: "JSON",
                    success: function (res) {
                        {#console.log(res);#}
                        if (res.status) {
                            // 数据提交正确跳转地址
                            location.href = res.data;
                        } else {
                            $.each(res.error, function (key, value) {
                                $('#id_' + key).next().text(value[0])
                            })
                        }
                    }
                });
                // 2，数据ajax发送到后端
            });
        }
    </script>
{% endblock %}